## IN THE CLAIMS:



I/O transactions at I/O ports of a multiprocessor computer system comprising the steps

of:

determining the number and type of transactions anticipated at a port,

determining the number and type of devices being serviced via the port,

setting criteria for transactions at the port with respect to the number and type of

transactions and devices,

assigning the system resources to the port with respect to the criteria.

2. (original) The method as defined in claim 1 further comprising the steps of:

providing at least one control register for each port, wherein the control register 2

includes a plurality of programmable fields.

3. (original) The method as defined in claim 2 further comprising the steps of config-1

uring the control register fields to contain a number of direct memory access engines 2

available at a port to support a transaction, a number of cache lines for requested data, 3

and a number representing priorities among the anticipated transactions.

4. (original) The method as defined in claim 1 further comprising the step of preparing 1

for hot swapping an assembly, wherein the preparing for hot swapping comprises, with 2

respect to the assembly being replaced, copying the assembly's state, the state of its asso-3

ciated memory systems, its status and control registers, and the contents of its cache and

memory systems. 5

5. (original) The method as defined in claim 4 wherein the copying comprises the steps 1

of: 2

| 3  | flushing the data in the local cache and local memory to storage not affected by       |
|----|----------------------------------------------------------------------------------------|
| 4  | the hot swapping,                                                                      |
| 5  | invalidating data in cache,                                                            |
| 6  | setting a flush indicator in the port's cache status and control register,             |
| 7  | flushing directory data to non-affected storage,                                       |
| 8  | finding and stopping any new transactions,                                             |
| 9  | completing any transactions already started or pending,                                |
| 10 | flushing the translation look-aside buffers,                                           |
| 11 | invalidating the contents of the translation look-aside buffers, and                   |
| 12 | updating the system directory.                                                         |
|    |                                                                                        |
| 1  | 6. (original) A system for allocating system resources to accommodate I/O transaction  |
| 2  | at I/O ports of a multiprocessor computer system comprising:                           |
| 3  | the number and type of transactions anticipated at a port,                             |
| 4  | number and type of devices being serviced via the port,                                |
| 5  | criteria for operations at the port with respect to the number and type of transac-    |
| 6  | tions and devices,                                                                     |
| 7  | means for assigning the system resources to the port with respect to the criteria.     |
|    |                                                                                        |
| 1  | 7. (original) The system as defined in claim 6 further comprising:                     |
| 2  | at least one control register for each port, wherein the control register includes a   |
| 3  | plurality of programmable fields.                                                      |
|    |                                                                                        |
| 1  | 8. (original) The system as defined in claim 7 wherein the control register fields in- |
| 2  |                                                                                        |
| 3  |                                                                                        |
| 4  | among the anticipated transactions.                                                    |
|    | m de la la desta de la lacia de funda comunic                                          |
| 1  | 9. (previously presented) The method system as defined in claim 6 further compris      |
| 2  | e ing:                                                                                 |

| ,                | means for hot swapping of an assembly, including means for copying the assem-                                                                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3                | bly's state, the state of its associated memory systems, its status and control registers, and                                                                                                                                                                                            |
| 5                | the contents of its cache and memory systems.                                                                                                                                                                                                                                             |
| 1 2 3            | 10. (original) The system as defined in claim 9 wherein the means for copying comprises::  means for flushing the data in the local cache and local memory to storage not affected by the hot swapping,                                                                                   |
| 4                | means for flushing, modifying and invalidating unmodified data in cache,                                                                                                                                                                                                                  |
| 5<br>6           | means for setting a flush indicator in the port's cache status and control register,                                                                                                                                                                                                      |
| 7                | means for flushing directory data to non-affected storage,                                                                                                                                                                                                                                |
| 8                | means for finding and stopping any new transactions,                                                                                                                                                                                                                                      |
| 9                | means for completing any transactions already started or pending,                                                                                                                                                                                                                         |
| 10               | means for flushing the translation look-aside buffers,                                                                                                                                                                                                                                    |
| 11               | means for invalidating the contents of the translation look-aside buffers, and                                                                                                                                                                                                            |
| 12               | means for updating the directory.                                                                                                                                                                                                                                                         |
| 1<br>2<br>3<br>4 | 11. (previously presented) The method as defined in claim 1 herein the criteria comprises system needs with respect to operating speed, latency, priority, including low priority, debugging, communications credits, hot swapping, main and cache storage space, and control registers.  |
| 1<br>2<br>3<br>4 | 12. (previously presented) The system as defined in claim 6 wherein the criteria comprises system needs with respect to operating speed, latency, priority, including low priority, debugging, communications credits, hot swapping, main and cache storage space, and control registers. |

(2)

13. (new) A method for programmably allocating system resources to accommodate I/O transactions at I/O ports of a multiprocessor computer system comprising the steps of:

determining the number and types of transactions anticipated at a port,
determining the number and types of devices being serviced via the port,
identifying assemblies for hot swapping,
copying the states and status of those assemblies,
copying the states and status of the memory systems associated with those assemblies,
copying the contents of control registers associated with those assemblies,
copying the contents of cache memories associated with those assemblies,
determining the operating speeds and latency for transactions at the port,
in addition to the above, setting other criteria for transactions at the port with respect to the number and types of transactions and devices, and

with respect to the numbers and types of transactions and devices at the ports, assigning system resources to the ports.

18

9

10

11

12

13

14

15

16

17

- 1 14.(new) The method as defined in claim 13 wherein the step of assigning system
  2 resources to the ports includes assigning control registers to the ports, assigning direct
  3 memory access engines to the ports, assigning cache memory to the ports and assigning
  4 priorities among the transactions at the ports.
- 1 15. (new) A system for programmably allocating system resources to accommodate
  2 I/O transactions at I/O ports of a multiprocessor computer system, the system comprising:
  3 means for determining the number and types of transactions anticipated at a port,

CI Contid.

74

|    |        | mans for determining the number    | r and types of devices being serviced via the           |
|----|--------|------------------------------------|---------------------------------------------------------|
| 4  |        | means for determining and and      | ···                                                     |
| 5  | port,  |                                    |                                                         |
| 6  |        | assemblies identified for hot swa  | pping,                                                  |
| 7  |        | means for copying the states and   | status of those assemblies,                             |
| 8  |        | means for copying the states and   | status of the memory systems associated with            |
| 9  |        | those assemblies,                  |                                                         |
| 10 |        | means for control the contents of  | fregisters associated with those assemblies,            |
| 11 |        | means for copying the contents     | of cache memories associated with those assem-          |
| 12 |        | blies,                             |                                                         |
| 13 |        | means for determining the opera    | ating speeds and latency for transactions at the        |
| 14 |        | port,                              |                                                         |
| 15 |        | means for determining priority     | of transactions at the port,                            |
| 16 |        | in addition to the above, means    | for setting other criteria for transactions at the port |
| 17 | with 1 | respect to the number and types of | f transactions and devices, and                         |
|    | With   | with respect to the criteria DUI   | bers and types of transactions and devices at the       |
| 18 |        |                                    |                                                         |
| 19 | ports  | , means for assigning system reso  | urces w me ports.                                       |
| 20 |        |                                    |                                                         |

- 1 16.(new) The system as defined in claim 15 wherein the system resources assigned
- to the ports includes control registers, direct memory access engines, cache memory and
- means foe assigning priorities among the transactions at the ports.